import { GetServerSideProps, NextPage } from 'next' import React, { useEffect } from 'react' import dynamic from 'next/dynamic' import cookie from 'cookie' import { getProductById } from '~/services/product' import { getIdFromSlug } from '~/libs/slug' import { IProductDetail } from '~/types/product' import { Seo } from '~/components/seo' import { useRouter } from 'next/router' import { useProductContext } from '@/contexts/ProductContext' const BasicLayout = dynamic(() => import('@/core/components/layouts/BasicLayout'), { ssr: false }) const ProductDetail = dynamic(() => import('~/modules/product-detail'), { ssr: false }) type PageProps = { product: IProductDetail } export const getServerSideProps: GetServerSideProps = (async (context) => { const { slug } = context.query const cookieString = context.req.headers.cookie; const cookies = cookieString ? cookie.parse(cookieString) : {}; const auth = cookies?.auth ? JSON.parse(cookies.auth) : {}; const tier = auth?.pricelist || '' const productId = getIdFromSlug(slug as string) const product = await getProductById(productId, tier) if (!product) return { notFound: true } return { props: { product } } }) const SELF_HOST = process.env.NEXT_PUBLIC_SELF_HOST const ProductDetailPage: NextPage = ({ product }) => { const router = useRouter(); const { setProduct } = useProductContext(); useEffect(() => { if (product) setProduct(product); }, [product, setProduct]); return (
) } export default ProductDetailPage